ActivityMask.tsx 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. "use client";
  2. import { useWalletStore } from "@/stores/useWalletStore";
  3. import { Mask } from "antd-mobile";
  4. import { useEffect, useState } from "react";
  5. const ActivityMask = () => {
  6. const [visible, setVisible] = useState<boolean>(false);
  7. const wallet = useWalletStore((state) => state.wallet);
  8. console.log(`🚀🚀🚀🚀🚀-> in ActivityMask.tsx on 10`, wallet);
  9. useEffect(() => {
  10. if (wallet?.notice?.lose_score > 0) {
  11. setVisible(true);
  12. }
  13. }, [wallet?.notice?.lose_score]);
  14. return (
  15. <Mask visible={visible} destroyOnClose={true} getContainer={null}>
  16. {/*<div*/}
  17. {/* className={"absolute right-[0.2083rem] top-[20%] z-50"}*/}
  18. {/* onClick={() => setVisible(false)}*/}
  19. {/*>*/}
  20. {/* <span className={"iconfont icon-guanbi"}></span>*/}
  21. {/*</div>*/}
  22. <div className={"absolute top-[20%] z-50"}>
  23. <div className={"h-[4.2rem] w-[100%]"}>
  24. <div
  25. className={"iconfont icon-guanbi absolute right-[30px]"}
  26. onClick={() => setVisible(false)}
  27. ></div>
  28. <img src={"/doings/activity.png"} className={"h-[4.1667rem] object-contain"} />
  29. <div
  30. className={
  31. "absolute -left-[8%] top-[28%] h-[2.0833rem] w-[56%]" +
  32. " translate-x-1/2" +
  33. " p-[0.0694rem] text-[#000]"
  34. }
  35. >
  36. <div className={"text-center font-bold"}>Um presente</div>
  37. <div className={"mt-[0.0294rem] text-center"}>
  38. <span>Não tive sorte hoje,</span>
  39. <span>Continue com o bom trabalho</span>
  40. </div>
  41. <div className={"mt-[0.4167rem] flex items-center justify-center"}>
  42. <span className={"mr-[0.0694rem]"}>presente: </span>
  43. <span className={"text-[0.2083rem] font-bold"}>
  44. {wallet.gift_packet.amount}
  45. </span>
  46. </div>
  47. </div>
  48. </div>
  49. </div>
  50. </Mask>
  51. );
  52. };
  53. export default ActivityMask;